

MG0007

## 从SXX32F103移植到AT32F403A

## 前言

本应用笔记旨在帮助您分析从现有的SXX32F103器件移植到AT32F403A器件所需的步骤。本文档收集了最重要的信息,并列出了需要注意的重要事项。

要将应用程序从SXX32F103系列移植到AT32F403A系列,用户需要分析硬件移植、外设移植和固件移植。

支持型号列表:

| 支持型号 AT32F403Axxxx |
|--------------------|
|--------------------|



# 目录

| 1 | AT3 | AT32F403A 与 SXX32F103 异同 |                              |    |  |  |  |  |
|---|-----|--------------------------|------------------------------|----|--|--|--|--|
|   | 1.1 | 相同点                      | 頁概述                          | 6  |  |  |  |  |
|   | 1.2 | 差异点                      | 5概述                          | 6  |  |  |  |  |
| 2 | 快速  | 楚换 S                     | XX32F103 芯片                  | 8  |  |  |  |  |
|   | 2.1 | 快速验                      | <b>d</b> 证兼容性                | 8  |  |  |  |  |
|   | 2.2 | BSP ]                    | 工程替换步骤                       | 8  |  |  |  |  |
| 3 | AT3 | 2F403 <i>A</i>           | <b>A</b> 兼容性解析               | 10 |  |  |  |  |
|   | 3.1 | 功能增                      | 9强                           | 10 |  |  |  |  |
|   |     | 3.1.1                    | FPU 的 ARM® 32 位的 Cortex®-M4F | 10 |  |  |  |  |
|   |     | 3.1.2                    | 安全库区保护                       | 10 |  |  |  |  |
|   |     | 3.1.3                    | 高频 PLL 设定                    | 10 |  |  |  |  |
|   |     | 3.1.4                    | 预分频器扩增                       | 11 |  |  |  |  |
|   |     | 3.1.5                    | 内存容量扩展                       | 11 |  |  |  |  |
|   |     | 3.1.6                    | 加挂 SPI 闪存(SPIM 功能)           | 12 |  |  |  |  |
|   |     | 3.1.7                    | 扩增 SDIO2                     | 12 |  |  |  |  |
|   |     | 3.1.8                    | 扩增 I2C3                      | 13 |  |  |  |  |
|   |     | 3.1.9                    | 扩增 SPI4                      | 13 |  |  |  |  |
|   |     | 3.1.10                   | 扩增全双工 I2S                    | 13 |  |  |  |  |
|   |     | 3.1.11                   | 扩增 USART 和 UART              | 13 |  |  |  |  |
|   |     | 3.1.12                   | 扩增 CAN2                      | 14 |  |  |  |  |
|   |     | 3.1.13                   | 支持 CAN 与 USB 同时使用            | 14 |  |  |  |  |
|   |     | 3.1.14                   | 32 位定时器                      | 14 |  |  |  |  |
|   |     | 3.1.15                   | SPI1 复用为 I2S1                | 14 |  |  |  |  |
|   |     | 3.1.16                   | USBDEV 缓冲区                   | 14 |  |  |  |  |
|   |     | 3.1.17                   | 扩增 48MHz HSI 支持 USB 外设       | 15 |  |  |  |  |
|   |     | 3.1.18                   | HSI 自动时钟校准 ACC               | 15 |  |  |  |  |
|   |     | 3.1.19                   | 64PIN 封装支持 XMC               | 15 |  |  |  |  |
|   |     | 3.1.20                   | 支持闪存 CRC 校验                  | 16 |  |  |  |  |





| 4 | 版本原 | 万史     |                                    | 25  |
|---|-----|--------|------------------------------------|-----|
|   |     | 3.2.20 | PWR 以 WFE 进入 low-power 模式的差别       | .24 |
|   |     |        | USART 智能卡模式下接收数据异常                 |     |
|   |     |        | Systick 中断异常唤醒执行 WFE 进入的 Stop Mode |     |
|   |     |        | STOP Mode 下无法停掉 MCO 输出             |     |
|   |     |        | 使用 WWDG 中断时,无法清除 EWIF 标志           |     |
|   |     |        | 使用 ADC 双模式时,程序卡在判断 CAL 控制位为零的循环中   |     |
|   |     |        | GPIO 在 50MHz 配置下高频输出时存在过冲现象        |     |
|   |     |        | I2S 从机在特定条件下使能会导致通讯数据错误且无法自动恢复     |     |
|   |     |        | SDIO 在发生 RX over run 之后接收数据异常      |     |
|   |     |        | Flash sector erase 更长              |     |
|   |     | 3.2.10 | DAC 输出有毛刺                          | .21 |
|   |     | 3.2.9  | USB_DP 存在内部上拉电阻                    | .21 |
|   |     | 3.2.8  | USB 双缓冲区 SW_BUF 和 DTOG 区别          | .21 |
|   |     | 3.2.7  | 使用 USB 模块时系统时钟频率须不小于 12MHz         | .21 |
|   |     | 3.2.6  | Standby 模式下自动使能 PAO 引脚下拉电阻         | .20 |
|   |     | 3.2.5  | BOOT0 自带下拉电阻                       | .20 |
|   |     | 3.2.4  | GPIO 5V 容忍管脚兼容                     | .20 |
|   |     | 3.2.3  | ADC 要求较长的采样时间                      | .20 |
|   |     | 3.2.2  | 内部温度传感器                            |     |
|   |     | 3.2.1  | 高频下 PLL 切换导致程序挂起或 hard fault       |     |
|   | 3.2 |        | 用区别                                |     |
|   |     | 3.1.22 | 扩增 DMA 弹性映像请求功能                    | .17 |
|   |     | 3.1.21 | 向迷 GPIU                            | .10 |





# 表目录

| 表 1. SXX32F103 与 AT32F403A 差异概述          | 6  |
|------------------------------------------|----|
| 表 2. BSP 替换步骤概述                          |    |
| 表 3. SPI 闪存支持类型表                         |    |
| 表 4. EXT_SPIF_GRMP[2:0]为[000]时引脚支持       | 12 |
| 表 5. EXT_SPIF_GRMP[2:0]为[001]时引脚支持       |    |
| 表 6. SXX32F103/403A GPIO toggle 最大速度性能测试 |    |
| 表 7. 文档版本历史                              |    |





# 图目录

| 图 1. | 403A 在 192MHz 主频下 GPIO 最快翻转速度波型     | 16 |
|------|-------------------------------------|----|
| 图 2. | 403A 在 72MHz 主频下 GPIO 最快翻转速度波型      | 17 |
| 图 3. | SXX32F103 在 72MHz 主频下 GPIO 最快翻转速度波型 | 17 |
| 图 4. | V <sub>SENSE</sub> 对温度理想曲线图         | 20 |
| 图 5. | USB 双缓冲区使用说明                        | 21 |



## 1 AT32F403A 与 SXX32F103 异同

AT32F403A 系列微控制器基本兼容 SXX32F103 系列,同时强化许多功能的关系,有些许地方与 SXX32F103 不同,详述于本文档。

## 1.1 相同点概述

- 管脚定义:相同封装管脚定义相同。为扩增的外设作管脚复用定义延伸
- 寻址空间:内存与寄存器逻辑地址相同。扩增的外设占用SXX32保留空间
- 函数库文件:函数库相同。部分头文件依照强化功能优化
- 编译工具:完全相同,例如Keil, IAR

## 1.2 差异点概述

表 1. SXX32F103 与 AT32F403A 差异概述

|                           | AT32F403A                                                         | SXX32F103                           |
|---------------------------|-------------------------------------------------------------------|-------------------------------------|
| 系统                        |                                                                   |                                     |
| 内核                        | Cortex-M4 并支持 DSP 指令及浮点运算单元 FPU                                   | Cortex-M3                           |
| 系统时钟                      | 主频 240MHz,APB1 与 APB2 总线皆为<br>120MHz                              | 主频 72MHz, APB1 36MHz, APB2<br>72MHz |
| 启动                        | 13 ms                                                             | 2.5 ms                              |
| 重置                        | 8 ms                                                              | -                                   |
| Standby 唤醒                | 8 ms                                                              | 50 us                               |
| SRAM 容量                   | 扩充模式可达 224KB                                                      | 96KB                                |
| 加挂 SPI 闪存                 | 支持加挂 SPI flash 为 SPIM,最高达<br>16M Bytes                            | 无支援                                 |
| 系统存储器<br>(System          | 全系列 18KB,比 SXX32F103 多支持以<br>下功能:                                 | 依型号分 6KB/2KB                        |
| Memory)                   | 1. USB DFU 方式的 ISP 烧写                                             |                                     |
|                           | 2. 对 SPIM 进行 ISP 烧写                                               |                                     |
|                           | 3. 对闪存内容进行 CRC 校验                                                 |                                     |
| 选择字节<br>(Option Byte)     | 48 Bytes, 扩增以下设定功能:<br>1. SRAM 模式设定                               | 16 Bytes                            |
|                           | 2. 4 Bytes 自定义字段(例如开发商 ID)                                        |                                     |
|                           | 3. 8 Bytes SPIM 加密钥匙                                              |                                     |
| 闪存 <b>16-bit</b> 写<br>入时间 | 50 μs                                                             | 52.5 µs                             |
| 闪存页擦除时<br>间               | 50 ms                                                             | 40 ms                               |
| 闪存整片擦除<br>时间              | 0.8 s (AT32F403AxC)<br>1.4 s (AT32F403AxE)<br>2.8 s (AT32F403AxG) | 40 ms                               |



|                              | AT32F403A                                                                          | SXX32F103                                                           |  |
|------------------------------|------------------------------------------------------------------------------------|---------------------------------------------------------------------|--|
| 外设                           |                                                                                    |                                                                     |  |
| 安全库区保护                       | 支持                                                                                 | 无                                                                   |  |
| 备份寄存器                        | 全系列支持 42 组半字节备份寄存器                                                                 | 中、小容量系列仅支持 10 组                                                     |  |
| 扩增 I2C                       | 多一组 I2C                                                                            | I2C1/2                                                              |  |
| 扩增 SPI                       | 多一组 SPI4                                                                           | SPI1/2/3                                                            |  |
| 扩增 SDIO                      | 多一组 SDIO2                                                                          | SDIO1                                                               |  |
| 扩增 USART<br>和 UART           | 支持 USART6/UART7/UART8                                                              | 不支持 USART6/UART7/UART8                                              |  |
| SPI1 支援 I2S                  | SPI1 可支持 I₂S 功能                                                                    | SPI1 仅为 SPI 功能                                                      |  |
| I2S 支援                       | 48PIN 有 I <sup>2</sup> S                                                           | 48PIN 无 I <sup>2</sup> S                                            |  |
|                              | I <sup>2</sup> S2/3 支持全双工                                                          | 不支持全双工 I <sup>2</sup> S                                             |  |
| 扩增 CAN2                      | 支持 CAN2                                                                            | 不支持 CAN2                                                            |  |
| 支持 CAN 与<br>USB 同时使用         | 支持                                                                                 | 不支持                                                                 |  |
| 扩增 48MHz<br>HSI 支持 USB<br>外设 | 支持                                                                                 | 不支持                                                                 |  |
| HSI 自动时钟<br>校准 ACC           | 支持                                                                                 | 不支持                                                                 |  |
| XMC                          | 1. 不支持CF卡; 支持复用信号的 NOR/PSRAM或借由外部器件支持非 复用信号的SRAM/PSRAM(参照 AN0068)                  | 1. 支持CF卡和<br>NOR/SRAM/PSRAM                                         |  |
|                              | <ol> <li>2. 2个片选</li> <li>3. 不支持外部中断</li> <li>4. 64 引脚封装支持 8 位 LCD 并口屏用</li> </ol> | <ul><li>2. 4个片选</li><li>3. 支持2个外部中断</li><li>4. 64 引脚封装不支持</li></ul> |  |
| 支持闪存<br>CRC 校验               | 支持                                                                                 | 不支持                                                                 |  |
| 高速 GPIO                      | GPIO 挂在 AHB 总线上                                                                    | GPIO 挂在 APB 总线上                                                     |  |
| 扩展储存接口                       | 64PIN 以上及支持总线输出(XMC)                                                               | 144PIN 并且 256KB 闪存以上才支持总线输出                                         |  |
| 32 位定时器                      | TMR2, TMR5 为 32 位定时器                                                               | 皆为 16 位                                                             |  |
| USB 缓冲区                      | 可扩充为 768 Byte                                                                      | 512 Byte                                                            |  |
| ADC                          | 2 Msps (max ADCCLK = 28 MHz)                                                       | 1 Msps (max ADCCLK = 14 MHz)                                        |  |
| ADC 触发事件                     | 支持 TMR1, TMR8 及 TMR15                                                              | 无 TMR15                                                             |  |
| 温度传感器                        | 正温度系数                                                                              | 负温度系数                                                               |  |
| 电气                           |                                                                                    |                                                                     |  |
| 电压范围                         | 2.6V~3.6V                                                                          | 2.0V~3.6V                                                           |  |
| 环境温度 T <sub>A</sub>          | -40°C~+105°C                                                                       | -40°C~+85°C                                                         |  |
| 内核电压                         | 1.2V                                                                               | 1.8V                                                                |  |
| ESD 参数                       | HBM:5KV, CDM:1000V                                                                 | HBM:2KV, CDM:500V                                                   |  |
| 运行模式                         | 37.1 mA @ 72MHz                                                                    | 51 mA @ 72MHz                                                       |  |
| 睡眠功耗                         | 31.8 mA @ 72MHz                                                                    | 29.5mA @ 72MHz                                                      |  |
| 停机功耗                         | 1.4 mA                                                                             | 25 uA                                                               |  |
| 待机功耗                         | 5.7 uA                                                                             | 2.1 uA                                                              |  |



## 2 快速替换 SXX32F103 芯片

## 2.1 快速验证兼容性

- 步骤一:解焊SXX32F103,换成AT32F403A对应型号
- 步骤二:使用雅特力ICP, ISP或KEIL, IAR下载SXX32F103 HEX文件或BIN文件。
- 步骤三:如果有需要,下载SXX32F103 HEX文件或BIN文件以外的资料或进行系统校正。
- 步骤四: 查看程序能否正常运行。
- 骤五:如果系统时钟源采用HSE,为了确保量产稳定性,请修改时钟初始化源代码,方法如下: 打开 system\_at32f4xx.c 找到当前的系统时钟频率配置函数,如 168MHz 函数: static void SetSysClockTo168(void)

然后按如下方式配置自动顺滑频率切换功能

```
/* Wait till PLL is ready */
while((RCC->CR & RCC_CR_PLLRDY) == 0)
{
}
*((unsigned int *)0x40021054) |= (0x30);// 开启自动滑顺频率切换功能

/* Select PLL as system clock source */
RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_SW));
RCC->CFGR |= (uint32_t)RCC_CFGR_SW_PLL;

/* Wait till PLL is used as system clock source */
while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS) != (uint32_t)0x08)
{
}
//此时不需再等待 200us

*((unsigned int *)0x40021054) &=~ (0x30)- // 关闭自动漫顺频率切换功能
```

- 步骤六:其他问题快速排查请参考3.2 外设使用区别
- 步骤七:如果经过上述步骤后程序仍无法正常运行,请参考本文件其他章节,或连络代理商及雅特力科技技术支持人员协助解决。

## 2.2 BSP 工程替换步骤

● 六种应用情形概述如下

表 2. BSP 替换步骤概述

| 序 | 使用什么 BSP/Pack 开              | 是否使用          | ALTH-Y-V+                                                                               |
|---|------------------------------|---------------|-----------------------------------------------------------------------------------------|
| 号 | 发                            | AT32F403A 新功能 | 处理方法                                                                                    |
| 1 | AT32F403A BSP/Pack           | 是/否           | 1. 结合 <u>3.2 外设使用区别</u> 修改对应程序                                                          |
| 2 | SXX32F103 BSP/Pack           | 否             | 1. 参考2.1在系统时钟切换之前开启时钟顺滑模式<br>2. 参考2.1在系统时钟切换之后关闭时钟顺滑模式<br>3. 结合3.2 外设使用区别修改对应程序         |
| 3 | SXX32F103 寄存器操<br>作          | 否             | 1. 参考2.1在系统时钟切换之前开启时钟顺滑模式<br>2. 参考2.1在系统时钟切换之后关闭时钟顺滑模式<br>3. 结合3.2 外设使用区别修改对应程序         |
| 4 | SXX32F103 BSP +<br>AT32 Pack | 否             | 1. 参考2.1在系统时钟切换之前开启时钟顺滑模式<br>2. 参考2.1在系统时钟切换之后关闭时钟顺滑模式<br>3. 修改FPU设置<br>4. 结合3.2 外设使用区别 |



## 从SXX32F103移植到AT32F403A

|   | SXX32F103 寄存器操     | _ | 1. | 参考2.1在系统时钟切换之前开启时钟顺滑模式      |
|---|--------------------|---|----|-----------------------------|
| 5 | 作                  | 是 | 2. | 参考2.1在系统时钟切换之后关闭时钟顺滑模式      |
|   | TF                 |   | 3. | 结合 <u>3.2 外设使用区别</u> 修改对应程序 |
|   |                    | _ | 1. | 参考2.1在系统时钟切换之前开启时钟顺滑模式      |
| 6 | SXX32F103 BSP/Pack | 是 | 2. | 参考2.1在系统时钟切换之后关闭时钟顺滑模式      |
|   |                    |   | 3. | 结合 <u>3.2 外设使用区别</u> 修改对应程序 |

● 详细请参阅《AT32F403ABSP和Pack应用指南》



## 3 AT32F403A 兼容性解析

## 3.1 功能增强

### 3.1.1 FPU的 ARM® 32位的 Cortex®-M4F

- 描述:
  - 带存储器保护单元(MPU)
  - 内建单周期乘法和硬件除法
  - 内建浮点运算(FPU)
  - 新增支持DSP指令集
  - 例程参考

AT32F4xx\_StdPeriph\_Lib\_V1.x.x\Project\Examples\AT\_START\_F403A\CortexM4\FPU AT32F4xx\_StdPeriph\_Lib\_V1.x.x\Libraries\CMSIS\DSP\_Lib\Examples

## 3.1.2 安全库区保护

- 描述
  - 目前越来越多的微控器(MCU)应用需要使用到复杂的算法及中间件解决方案(middleware solution),因此,如何保护软件方案商开发出来的核心算法等知识产权代码(IP-Code),便成为微控制器应用中一项很重要的课题。 为因应这一重要的需求,AT32F403A系列提供了安全库区(sLib)的功能,以防止重要的
- 使用范例
  - 请参考《AT32F403A 安全库区(SLIB) 应用指南.pdf》

## 3.1.3 高频 PLL 设定

- 描述:
  - AT32F403A内置的PLL可输出240MHz时钟,设定略有不同

IP-Code 被终端用户的程序做修改或读取,进而达到保护的目的。

- 该PLL支持两频段,以72MHz为分界,最高可达240MHz,须根据输出频率设定PLLRANGE 寄存器
- 使用范例:
  - SXX32F103 PLL设定程序范例:

    RCC->CFGR |= (uint32\_t)(RCC\_CFGR\_PLLSRC\_HSE | RCC\_CFGR\_PLLMULL9);
  - AT32F403A PLL设定程序范例:



```
#define RCC_CFG_PLLMULT1 ((uint32_t)0x20000000) /*!< PLL input clock * 17 */
#define RCC_CFG_PLLMULT18 ((uint32_t)0x20040000) /*!< PLL input clock * 18 */
#define RCC CFG PLLMULT19 ((uint32 t)0x20080000) /*!< PLL input clock * 19 */
#define RCC CFG PLLMULT20 ((uint32 t)0x200C0000) /*!< PLL input clock * 20 */
#define RCC CFG PLLMULT61 ((uint32 t)0x60300000) /*!< PLL input clock * 61 */
#define RCC CFG PLLMULT62 ((uint32 t)0x60340000) /*!< PLL input clock * 62 */
#define RCC CFG PLLMULT63 ((uint32 t)0x60380000) /*!< PLL input clock * 63 */
#define RCC CFG PLLMULT64 ((uint32 t)0x603C0000) /*!< PLL input clock * 64 */
#define RCC_CFG_PLLRANGE ((uint32_t)0x80000000) /*!< PLL Frequency range */
#define RCC CFG PLLRANGE LE72MHZ ((uint32 t)0x00000000) /*!< When PLL frequency is
less than or equal to 72MHz */
#define RCC CFG PLLRANGE GT72MHZ ((uint32_t)0x80000000) /*!< When PLL
frequency is greater than 72MHz */
以设置 72MHz 为例:
RCC->CFG |= (uint32_t)(RCC_CFG_PLLRC_HSE | RCC_CFG_PLLMULT9 |
RCC CFG PLLRANGE LE72MHZ);
以设置 200MHz 为例:
RCC->CFG |= (uint32 t)(RCC CFG PLLRC HSE | RCC CFG PLLMULT25 |
```

### 3.1.4 预分频器扩增

- 描述:
  - 由于主频提高至240MHz,相关预分频器做出扩增
  - USB预分频器扩增支援/2, /2.5, /3, /3.5, /4输出
  - ADC预分频器扩增支持/12, /16输出
  - HSE预分频器扩增支持/3, /4, /5输出
  - 主时钟输出 (CLKOUT) 扩增支持 CLKOUT 预分频器, 可以实现 CLKOUT/2. CLKOUT/4...CLKOUT/512除频
  - 主时钟输出(CLKOUT)扩增支持LSE, LSI, PLLCLK/4, USB48M, ADCCLK输出
  - 请参阅AT32F403A参考手册3.3.2 RCC\_CFG寄存器和3.3.12 额外寄存器(RCC\_MISC)叙述

## 3.1.5 内存容量扩展

- 描述:
  - AT32F403A支持内存扩展功能,可将内存由96KB扩展为224KB
  - 若开起此模式,则具备零等待特性的闪存地址空间将限制为128KB
  - 内存扩展功能透过选择字节EOPB0[7:0] (0x1FFF F810) 设定 0xFE: 片上内存为 224K 字节 0xFF: 片上内存为 96K 字节

其他设置保留

- 选择字节EOPB0更新后须重置系统方能生效
- 请参阅AT32F403A参考手册5.3.4节
- 例程参考 AT32F4xx\_StdPeriph\_Lib\_V1.x.x\Project\Examples\AT\_START\_F403\SRAM



## 3.1.6 加挂 SPI 闪存(SPIM 功能)

#### ● 描述:

- AT32F403A支持加挂SPI闪存,支持下列及其兼容之型号,容量可达16M Byte。如果无法判别 SPI FLASH 型号是否兼容,可以利用AT32 ICP工具的SPIM自动侦测功能
- 请参阅AT32F403A参考手册5.2.2节与5.4.14节
- 支持下表SPI Flash型号外,也支持兼容下表型号命令集的SPI Flash芯片

表 3. SPI 闪存支持类型表

| Vendor  | SPI Flash 型号                                  |
|---------|-----------------------------------------------|
| ESMT    | EN25F20A/EN25QH128A                           |
| Winbond | W25Q128V                                      |
| GD      | GD25Q16C/GD25Q32C/GD25Q64C/GD25Q80C/GD25Q127C |

- 加挂闪存为SPIM,使用地址0x0840 0000~0x1FFF 0000
- 加挂闪存功能在各型封装均支持。SPIM\_IO0和SPIM\_IO01管脚可根据 EXT\_SPIF\_GRMP[2:0]进行remap配置。使用管脚如下表:

表 4. EXT SPIF GRMP[2:0]为[000]时引脚支持

| <b> </b> |      |                 |            |             |                                        |  |  |  |
|----------|------|-----------------|------------|-------------|----------------------------------------|--|--|--|
| SPIM     | Pin  | LQFP48<br>QFN48 | LQF<br>P64 | LQF<br>P100 | 共享脚位描述                                 |  |  |  |
| SPIM_SCK | PB1  | 19              | 27         | 36          | ADC12_IN9/TMR3_CH4/TMR8_CH3<br>N       |  |  |  |
| SPIM_NSS | PA8  | 29              | 41         | 67          | TMR1_CH1/CLKOUT/USART1_CK/I<br>2C3_SCL |  |  |  |
| SPIM_IO0 | PA11 | 32              | 44         | 70          | USB_DM/TMR1_CH4/USART1_CTS/<br>CAN_RX  |  |  |  |
| SPIM_IO1 | PA12 | 33              | 45         | 71          | USB_DP/CAN_TX/USART1_RTS<br>/TMR1_ETR  |  |  |  |
| SPIM_IO2 | PB7  | 43              | 59         | 93          | TMR4_CH2/I2C1_SDA/XMC_NADV             |  |  |  |
| SPIM_IO3 | PB6  | 42              | 58         | 92          | TMR4_CH1/I2C1_SCL                      |  |  |  |

表 5. EXT\_SPIF\_GRMP[2:0]为[001]时引脚支持

| SPIM     | Pin  | LQFP48<br>QFN48 | LQF<br>P64 | LQF<br>P100 | 共享脚位描述                                   |
|----------|------|-----------------|------------|-------------|------------------------------------------|
| SPIM_SCK | PB1  | 19              | 27         | 36          | ADC12_IN9/TMR3_CH4/TMR8_CH3<br>N         |
| SPIM_NSS | PA8  | 29              | 41         | 67          | TMR1_CH1/CLKOUT/USART1_CK/I<br>2C3_SCL   |
| SPIM_IO0 | PB10 | 21              | 29         | 47          | USART3_TX/I2C2_SCL/I2S3_MCK/T<br>MR2_CH3 |
| SPIM_IO1 | PB11 | 22              | 30         | 48          | USART3_RX/I2C2_SDA/TMR2_CH4              |
| SPIM_IO2 | PB7  | 43              | 59         | 93          | TMR4_CH2/I2C1_SDA/XMC_NADV               |
| SPIM_IO3 | PB6  | 42              | 58         | 92          | TMR4_CH1/I2C1_SCL                        |

■ 例程参考 AT32F4xx\_StdPeriph\_Lib\_V1.x.x\Project\Examples\AT\_START\_F403A\FLASH

## 3.1.7 扩增 SDIO2

- 描述:
  - AT32F403A扩增SDIO2
  - 适用于48PIN/64PIN/100PIN封装,其中48PIN封装只支持SDIO2



- 寄存器起始地址: 0x4002\_3400
- 中断号: IRQ60
- DMA: 使用DMA2通道5
- 管脚复用设定:于AFIO\_MAP2寄存器位[20:19]扩充SDIO2复用重映像SDIO2\_REMAP[1:0] (请参阅AT32F403A参考手册7.4.11小节)

### 3.1.8 扩增 I2C3

- 描述:
  - AT32F403A扩增I2C3
  - 适用于64PIN/100PIN封装
  - 寄存器起始地址: 0x4000 6800
  - 中断号: IRQ61, IRQ62
  - DMA: 使用DMA1信道2(TX)与通道3(RX)
  - 管脚复用设定:于AFIO\_MAP2寄存器位[18]扩充I2C3复用重映像I2C3\_REMAP(请参阅AT32F403A参考手册7.4.8小节)

### 3.1.9 扩增 SPI4

- 描述:
  - AT32F403A扩增SPI4/I2S4
  - 适用于64PIN/100PIN封装
  - 寄存器起始地址: 0x4002\_3400
  - 中断号: IRQ63
  - DMA: 使用DMA2信道3(RX)与通道4(TX)
  - 管脚复用设定:于AFIO\_MAP2寄存器位[17]扩充SPI4复用重映像SPI4\_REMAP(请参阅AT32F403A参考手册7.4.10小节)

## 3.1.10 扩增全双工 I2S

- 描述:
  - AT32F403A 新增两个模块(I2S2 ext, I2S3 ext)以支持I2S全双工模式
  - 适用于48PIN/64PIN/100PIN封装
  - I2Sx\_ext不能独立使用,只能配合I2Sx一起用于全双工模式,且I2Sx\_ext需配置为从机
  - 全双工模式下,原I2S模式未用的SPI MISO引脚用于扩增的数据线,其他引脚不变
  - I2Sx\_ext无独立的中断向量号(与I2Sx共享),但有独立的寄存器地址和DMA信道(请参阅AT32F403A参考手册1.2.1及9.3.8小节)

## 3.1.11 扩增 USART 和 UART

- 描述:
  - AT32F403A扩增USART6/UART7/UART8
  - 寄存器起始地址: USART6-0x4001\_6000, UART7-0x4001\_6400, UART8-0x4001\_6800
  - 中断号: IRQ76, IRQ77, IRQ78
  - DMA: 使用弹性请求(请参阅AT32F403A参考手册9.3.8小节)
  - 管脚复用设定:



于 AFIO\_MAP8 寄存器位[23:20]扩充 USART6 复用重映像 USART6\_GRMP(请参阅 AT32F403A 参考手册 7.4.7 小节)

于 AFIO\_MAP8 寄存器位[27:24]扩充 UART7 复用重映像 UART7\_GRMP (请参阅 AT32F403A 参考手册 7.4.7 小节)

于 AFIO\_MAP8 寄存器位[31:28]扩充 UART8 复用重映像 UART8\_GRMP(请参阅 AT32F403A 参考手册 7.4.7 小节)

### 3.1.12 扩增 CAN2

- 描述:
  - AT32F403A 扩增CAN2
  - 适用于48PIN/64PIN/100PIN封装
  - 寄存器起始地址: 0x4000 6800
  - 中断号: IRQ68, IRQ69, IRQ70, IRQ71
  - 管脚复用设定:于AFIO\_MAP寄存器位[22]扩充CAN2复用重映像CAN2\_REMAP(请参阅AT32F403A参考手册7.4.3小节)

### 3.1.13 支持 CAN 与 USB 同时使用

- 描述:
  - AT32F403A 支持CAN与USB同时使用
  - 适用于48PIN/64PIN/100PIN封装
  - CAN负责管理自己独立的512字节SRAM存储空间
  - USB也有自己独立的SRAM存储空间,且未使能的CAN的存储空间也可以叠加分配给USB使用(详细用法请参阅AT32F403A参考手册21.3.2.1小节)

## 3.1.14 32 位定时器

- 描述:
  - AT32F403A TMR2/TMR5 可配置成32位定时器
- 使用范例:
  - TMR2->CTRL1|=0X0400; //开启TMR2的32位模式
  - TMR5->CTRL1|=0X0400; //开启TMR5的32位模式 (相关变量须改为 32 位,请参考 AT32F403A 库文件 at32f40x\_tim.c at32f40x\_tim.h)

## 3.1.15 SPI1 复用为 I2S1

- 描述:
  - AT32F403A SPI1可复用为I2S1
  - 适用于48PIN/64PIN/100PIN封装
  - 增加I<sup>2</sup>S1 MCK引脚
  - 其他引脚,寄存器空间和中断号,DMA通道同SPI1

## 3.1.16 USBDEV 缓冲区

- 描述:
  - AT32F403AA USB设备(USBDEV)缓冲区最大可扩充为768 Bytes
  - 于USB768B(RCC\_MISC[24])设定(请参阅AT32F403A参考手册3.3.11小节)



- 512Byte模式:缓冲区地址范围0x4000 6000~0x4000 63FF
- 768Byte模式: 当USB768B 为1 时,SRAM 的大小为768~1280BYTE,地址范围为0x4000 7800~0x4000 81FF,缓冲区的大小与CAN1和CAN2 是否使能有关,当CAN1 和CAN2 都不使能时,USB 分组缓冲区最大可设定到1280 字节,当CAN1 或CAN2 任意一个使能,USB 分组缓冲区最大可设定到1024 字节,当CAN1 和CAN2 都使能时,USB 分组缓冲区最大可设定到768 字节。
- 768 Byte模式使用范例:
  - RCC->MISC |= 0x00000001 << 24; /\*打开USB768Byte模式\*/
  - #define PMAAddr 0x40007800 /\*使用768Byte模式,一定要修改缓冲区地址\*/

### 3.1.17 扩增 48MHz HSI 支持 USB 外设

- 描述:
  - AT32F403A支持48MHz时钟供USB使用
  - 适用于系统时钟和USB时钟同步情形,如系统时钟跑200MHz(PLL from HSE),USB外设仍需要使用情况。
  - 详情请参考请参阅AT32F403A参考手册3.2.2 HSI时钟
- 使用范例:
  - 请参考以下案例 AT32F4xx\_StdPeriph\_Lib\_V1.x.x/Project/AT\_START\_F403A/Examples/USB\_Device

### 3.1.18 HSI 自动时钟校准 ACC

- 描述:
  - AT32F403A新增ACC模块

HSI 自动时钟校准器(HSI ACC)利用USB 模块产生的SOF 信号(周期为1 毫秒)作为参考信号,实现对HSI 时钟的采样和校准。

- 本模块主要功能就是实现对USB 设备提供48MHz±0.25%精度的时钟
- 适用于所有封装
- 寄存器起始地址: 0x4001\_5800
- 中断号: IRQ72
- 使用范例:
  - 请参考以下范例: AT32F4xx\_StdPeriph\_Lib\_V1.x.x\Project\AT\_START\_F403A\Examples\ACC

### 3.1.19 64PIN 封装支持 XMC

- 描述:
  - AT32F403A在64PIN封装支持XMC,但XMC仅支持8位的8080/6800方式驱动LCD
  - 管脚复用设定:于AFIO\_MAP7寄存器位[17:16] XMC 内部重映射(请参阅AT32F403A参考手册7.4.13小节)
- 使用范例:
  - 请参考以下案例 AT32F4xx\_StdPeriph\_Lib\_V1.x.x/Project/AT\_START\_F403A/Examples/XMC/XMC\_LCD\_8 BIT



## 3.1.20 支持闪存 CRC 校验

#### 描述:

- AT32F403A支持闪存CRC校验,通过配置闪存CRC校验控制寄存器(CRC DR),即通过闪 存CRC校验结果寄存器(CRC\_OUTR)校验闪存内容。该功能在在读保护或者sLib情况下同 样适用。
- 详情请参考《AT32F403A系列 技术手册》中5.4.26 闪存CRC校验控制寄存器(CRC\_DR) 和5.4.27 闪存CRC校验结果寄存器(CRC\_OUTR)

### 3.1.21 高速 GPIO

#### 描述:

- AT32F403A对GPIO进行了升级,将GPIO时钟挂在AHB总线上,而SXX32F103的GPIO挂在 APB总线上。
- 在做GPIO翻转测试或者使用GPIO模拟SPI/USART/I2C等外设时,存在AT32F403A GPIO翻 转速度与SXX32F103相比,频率会更快。对比如下表

表 6. SXX32F103/403A GPIO toggle 最大速度性能测试

| 时钟频率配置(MHz)           | AHB=192; APB2=96 | AHB=72;APB2=72 | AHB=36;APB2=36 |
|-----------------------|------------------|----------------|----------------|
| SXX32F103 I/O 翻转(MHz) | 不支持              | 18             | 9              |
| AT32F403A I/O 翻转(MHz) | 96               | 36             | 18             |









#### 图 2. 403A 在 72MHz 主频下 GPIO 最快翻转速度波型





## 3.1.22 扩增 DMA 弹性映像请求功能

- 描述:
  - AT32F403A的DMA1/DMA2新增弹性映像请求功能
  - 适用于48PIN/64PIN/100PIN封装



## 从SXX32F103移植到AT32F403A

- 弹性映射与固定映射同时只能开启其一,二者不能同时开启
- 弹性映射请求无独立的中断向量号(与固定映射请求共享),但有独立的配置寄存器地址(请参阅AT32F403A参考手册)
- 使用范例:
  - 请参考以下范例:
    AT32F4xx\_StdPeriph\_Lib\_V1.x.x\Project\AT\_START\_F403A\Examples\DMA\SPI\_RAM\_FLEXIBLE。



### 3.2 外设使用区别

### 3.2.1 高频下 PLL 切换导致程序挂起或 hard fault

● 描述:

初始化RCC时,当系统时钟SYSCLK从低频状态(HSE/HSI)切换到高频PLL状态(PLL >108MHz以上)可能导致程序挂起或进入hard fault。

- 需要特别注意的:
  - 当AT32F403A内置的PLL为108MHz以上时钟时,PLL设定略有不同,需要操作自动滑顺频率切换功能
- 168MHz PLL使用范例:

打开 system\_sxx32f10x.c 找到当前的系统时钟频率配置函数(需经过上述 PLL 配置),如 168MHz 函数:

static void SetSysClockTo168(void)

增加如下斜黑体部分:

```
/* Wait till PLL is ready */
while((RCC->CR & RCC_CR_PLLRDY) == 0)
{
}

*((unsigned int *)0x40021054) |= (0x30);// 开启自动滑顺频率切换功能

/* Select PLL as system clock source */
RCC->CFGR &= (uint32_t)((uint32_t)~(RCC_CFGR_SW));
RCC->CFGR |= (uint32_t)RCC_CFGR_SW_PLL;

/* Wait till PLL is used as system clock source */
while ((RCC->CFGR & (uint32_t)RCC_CFGR_SWS) != (uint32_t)0x08)
{
}

*((unsigned int *)0x40021054) &=~ (0x30)- // 关闭自动漫顺熵塞切场功能
```

## 3.2.2 内部温度传感器

● 描述:

AT32F403A 温度传感器为正温度系数, SXX32F103 为负温度系数

● 解决方法:

按照数据手册中的值并利用下列公式得出温度:

V<sub>25</sub> = V<sub>SENSE</sub> 在 25°C 时的数值

Avg\_Slope = 温度与 V<sub>SENSE</sub> 曲线的平均斜率 (单位为 mV/℃).

V<sub>25</sub> 和 Avg Slope 必须根据数据手册中的典型值参与运算, AT32F403A 与 SXX32F103 不同。





图 4. V<sub>SENSE</sub> 对温度理想曲线图

例程参考 AT32F4xx\_StdPeriph\_Lib\_V1.x.x\Project\Examples\AT\_START\_F403\ADC\Temperature

#### ADC 要求较长的采样时间 3.2.3

描述:

ADC 采样电路为适应采样率提升至 2Msps,内部等效 RADC 和 CADC 值较大,要求较长的采样时 间。特别在 ADC 输入源阻抗较大时,需满足足够的采样时间以获得准确的转换数据并消除不同 ADC 输入通道转换时的 cross-talk。

解决方法:

使用时若遇到转换值不如预期,可先尝试设置采样时间至最大 239.5 个 ADC 时钟,再逐步减小 采样时间至合适设置。若可接受较长采样间隔,在不同通道转换间插入 VREFINT 转换也有让转换 数据准确的效果。

#### GPIO 5V 容忍管脚兼容 3.2.4

描述:

各封装的 PA11, PA12 与 64/48 管脚封装的 PD0, PD1 不属于 5V 电压输入容忍管脚,故这些管 脚输入电平不可超过 VDD + 0.3V。

解决方法:

使用时请留意此限制。

#### BOOT0 自带下拉电阻 3.2.5

描述:

使用 BOOT0 引脚时,由于 BOOT0 内部自带阻值约为  $90K\Omega$  的下拉电阻(不可禁用),因此, 在客户使用时,无需再额外外接下拉。

#### Standby 模式下自动使能 PAO 引脚下拉电阻 3.2.6

当芯片进入 standby 模式下时,PAO 引脚的下拉电阻会由芯片内控制线路自动使能,以避免引 脚浮空漏电。

- 解决方法:
- 请留意让PAO外部线路维持对此两引脚OV输入电平,否则系统会有微量额外耗电。



## 3.2.7 使用 USB 模块时系统时钟频率须不小于 12MHz

● 描述:

系统时钟频率小于 12MHz 时, USB 无法正常收发数据。

● 解决方法:

为满足 USB 正常收发数据的需求,系统时钟频率必须不小于 12MHz。

### 3.2.8 USB 双缓冲区 SW BUF 和 DTOG 区别

● 描述:

SXX32F103: 当软件翻转SW\_BUF,就认为释放一个缓冲,而不管SW\_BUF和DTOG是否冲突,可以继续接收或发送数据,SXX32F103的设计与文档上说明不符。

AT32: 软件翻转SW\_BUF, 当SW\_BUF和DTOG相等时,此时状态为NAK状态,不能接收或发送数据。完全按照文档说明设计。

● 解决方法:

按照AT32F403A参考手册说明使用

图 5. USB 双缓冲区使用说明

| 端点类型    | DTOG 位 | SW_BUF 位 | USB 模块使用的缓冲区          | 应用程序使用的缓冲区            |
|---------|--------|----------|-----------------------|-----------------------|
| IN 端点   | 0      | 1        | ADRn_TX_0 / CNTn_TX_0 | ADRn_TX_1 / CNTn_TX_1 |
|         | 1      | 0        | ADRn_TX_1 / CNTn_TX_1 | ADRn_TX_0 / CNTn_TX_0 |
|         | 0      | 0        | 无(1)                  | ADRn_TX_0 / CNTn_TX_0 |
|         | 1      | 1        | 无(1)                  | ADRn_TX_0 / CNTn_TX_0 |
| OUT 端点: | 0      | 1        | ADRn_RX_0 / CNTn_RX_0 | ADRn_RX_1 / CNTn_RX_1 |
|         | 1      | 0        | ADRn_RX_1 / CNTn_RX_1 | ADRn_RX_0 / CNTn_RX_0 |
|         | 0      | 0        | 无(1)                  | ADRn_RX_0 / CNTn_RX_0 |
|         | 1      | 1        | 无(1)                  | ADRn_RX_1 / CNTn_RX_1 |

## 3.2.9 USB\_DP 存在内部上拉电阻

描述。

在USB\_DP默认使能内部上拉电阻,支持全速设备。用户可以设置寄存器USB\_SOFEN中的PUO位为1关闭内部上拉。

## 3.2.10 DAC 输出有毛刺

● 描述:

在使用Timer触发DAC输出波形的过程中去改变BFF位的状态来改变驱动能力, 会导致毛刺的产生。

● 解决方法:

在触发 DAC 输出之前配置好 BFF 位的状态。

## 3.2.11 Flash sector erase 更长

● 描述:

因为 AT32F403A 的 Flash sector erase 时间为 50ms 左右比 SXX32F103 的 22ms 更长。这会导致一些应用上的时间要求不同。如在开启 WWDG 后立即进入 Flash sector erase,则可能导致来不及喂狗而发生复位。

● 解决方法:

针对上述应用,可以在擦除前先关闭 WWDG,擦除完成之后在开启 WWDG。



### 3.2.12 SDIO 在发生 RX over run 之后接收数据异常

● 描述:

如果使用的FIFO相关标志,例如RX FIFO half full来做接收数据判断,则接收数据会出现异常现象。 其原因在于,在发生了RX OVER RUN的时候,AT32会直接进入IDLE状态,FIFO相关标志都会被 硬件清零,SXXX32F103则保持在接收状态,不会清除FIFO相关标志。这里AT32设计更为合理。

● 解决方法: 开 RX over run 中断,中断里重启 DPSM。

### 3.2.13 I2S 从机在特定条件下使能会导致通讯数据错误且无法自动恢复

● 描述:

若从机使能在主机发送时钟的第 2 个 CLK 与第 3 个 CLK 之间时,会导致当前及之后的数据传输出现乱序。

● 解决方法: 确保从机使能必须要在主机 **CK** 引脚上的时钟到达之前完成。

## 3.2.14 GPIO 在 50MHz 配置下高频输出时存在过冲现象

● 描述:

对于 AT32F403A, 当 GPIO 端口配置为输出模式,选择最大输出频率为 50MHz 时,会存在输出高频信号存在过冲现象,有可能干扰电路并影响应用。

- 解决方法:
  - 情景一:对于常规使用,代码修改为GPIO\_Speed\_2MHz配置。
  - 情景二:对于强电流驱动,用户可根据AT32F403A数据手册5.3.12的描述,依需求可配置成不同的速度参数MDEx。
- 情景一使用范例:
  - 针对使用 SXX32F103 BSP/Pack情形,修改方法如下黑体字部分

GPIO\_InitStructure.GPIO\_Pin = GPIO\_Pin\_5;
GPIO\_InitStructure.GPIO\_Mode = GPIO\_Mode\_Out\_PP;
/\* 以下修改为针对使用 SXX32F103 BSP/Pack 情形 \*/
GPIO\_InitStructure.GPIO\_Speed = GPIO\_Speed\_2MHz;
GPIO\_Init(GPIOB, &GPIO\_InitStructure);

- 情景二使用范例:
  - ■略。

## 3.2.15 使用 ADC 双模式时,程序卡在判断 CAL 控制位为零的循环中

- 描述:
  - 在使用ADC双模式时,由于硬件不会清除CAL控制位,可能导致程序会卡在ADC校准函数 while(ADC\_GetCalibrationStatus(ADC1));
- 解决方法:
  - 修改ADC使能和校准函数顺序,如原ADC初始化函数



```
ADC_Configuration()
{
...
ADC_Ctrl(ADC1, ENABLE);
...
while(ADC_GetCalibrationStatus(ADC1));//程序会死在这里
...
ADC_Ctrl(ADC2, ENABLE);
...
while(ADC_GetCalibrationStatus(ADC2));
...
}
```

#### ■ 修改方式

```
ADC_Configuration()
{
...
ADC_Ctrl(ADC1, ENABLE);
...
ADC_Ctrl(ADC2, ENABLE);
...
while(ADC_GetCalibrationStatus(ADC1));
while(ADC_GetCalibrationStatus(ADC2));
...
...
...
}
```

## 3.2.16 使用 WWDG 中断时, 无法清除 EWIF 标志

- 描述:
  - 在使用WWDG的中断时,在进入中断程序中WWDG\_CNT = 0x40时无法清除EWIF标志,所以进入中断后需要先进行喂狗操作,再清除EWIF标志。
- 解决方法:
  - 在WWDG中断处理函数中,先进行喂狗操作,再清除EWIF标志。

```
void WWDG_IRQHandler(void)
{
    WWDG_SetCounter(127);
    WWDG_ClearFlag();
}
```

## 3.2.17 STOP Mode 下无法停掉 MCO 输出

● 描述:

进入STOP Mode后,MCO还会有clk输出(LSICLK时钟频率),增加功耗

● 解决方法:

在进入STOP模式前,通过软件关闭MCO输出,STOP唤醒后再重新配置



```
/*******进 Stop 前先关闭 MCO 输出*******/
RCC_CLKOUTConfig(RCC_CLKOUT_NOCLK, /*用户原始期望的分频配置*/);
PWR_EnterSTOPMode(PWR_Regulator_ON, PWR_STOPEntry_WFI);
/****** Stop 唤醒后重新配置 MCO 输出******/
RCC_CLKOUTConfig(/*用户原始期望的 MCO 时钟源*/, /*用户原始期望的分频配置*/);
```

## 3.2.18 Systick 中断异常唤醒执行 WFE 进入的 Stop Mode

● 描述:

进入STOP Mode后,Systick未停止计数,当发生计数到0中断时,会误唤醒STOP

● 解决方法:

在进Stop Mode之前先关闭Systick, 待退出Stop Mode时再重新打开Systick

```
/******进 Stop 前先关闭 Systick******/
SysTick->CTRL &= 0xFFFFFFFE;
PWR_EnterSTOPMode(PWR_Regulator_ON, PWR_STOPEntry_WFE);
/***** Stop 唤醒后重新开启 Systick ******/
SysTick->CTRL |= 0x1;
```

## 3.2.19 USART 智能卡模式下接收数据异常

● 描述:

初始化USART的智能卡模式时,若先使能USART再使能智能卡模式,USART 智能卡模式使能后的第一帧数据长度时段内无法接收数据。

● 解决方法:

使能USART之前先使能智能卡模式。

```
/*******先使能智能卡模式*******/
    /* Enable the NACK Transmission */
    USART_SmartCardNACKCmd(USARTx, ENABLE);
    /* Enable the Smartcard Interface */
    USART_SmartCardCmd(USARTx, ENABLE);

/*****配置完成后再使能 USART ******/
    USART_Cmd(USARTx, ENABLE);
```

## 3.2.20 PWR 以 WFE 进入 low-power 模式的差别

- AT32F403A系列采用Cortex-M4内核,WFE操作有所区别,需要按如下使用范例操作。
- 使用范例:
  - /\* Request Wait For Event \*/
  - \_\_SEV();
  - \_\_WFE();
  - \_\_WFE();



# 4 版本历史

表 7. 文档版本历史

| 日期         | 版本    | 变更                                                                        |
|------------|-------|---------------------------------------------------------------------------|
| 2019.12.19 | 1.0.0 | 最初版本                                                                      |
| 2020.02.24 | 1.0.1 | 修改系统频率和内部AHB时钟频率最高240 MHz,内部APB时钟频率最高120 MHz<br>格式调整                      |
| 2020.03.13 | 1.0.2 | 在V1.0.1版" <u>高速GPIO</u> "增加GPIO 波形对比图                                     |
| 2020.04.06 | 1.0.3 | 修正 <u>使用ADC双模式时,程序卡在判断CAL控制位为零的循环中</u>                                    |
| 2020.04.09 | 1.0.4 | 修改 <u>表2. BSP替换步骤概述</u> 中处理方法描述                                           |
| 2020.06.11 | 1.0.5 | 增加 <u>STOP Mode下无法停掉MCO输出</u><br>增加 <u>Systick中断异常唤醒执行WFE进入的Stop Mode</u> |
| 2020.08.11 | 1.0.6 | 增加 <i>USART智能卡模式下接收数据异常</i>                                               |
| 2021.03.04 | 1.0.7 | 新增 <u>PWR以WFE进入low-powe模式的差别</u>                                          |
| 2021.03.11 | 1.0.8 | 修改XMC对NOR/PSRAM/SRAM支持的描述                                                 |



#### 重要通知 - 请仔细阅读

买方自行负责对本文所述雅特力产品和服务的选择和使用,雅特力概不承担与选择或使用本文所述雅特力产品和服务相关的任何责任。

无论之前是否有过任何形式的表示,本文档不以任何方式对任何知识产权进行任何明示或默示的授权或许可。如果本文档任何部分涉及任何第三方产品或服务,不应被视为雅特力授权使用此类第三方产品或服务,或许可其中的任何知识产权,或者被视为涉及以任何方式使用任何此类第三方产品或服务或其中任何知识产权的保证。

除非在雅特力的销售条款中另有说明,否则,雅特力对雅特力产品的使用和 / 或销售不做任何明示或默示的保证,包括但不限于有关适销性、适合特定用途(及其依据任何司法管辖区的法律的对应情况),或侵犯任何专利、版权或其他知识产权的默示保证。

雅特力产品并非设计或专门用于下列用途的产品: (A) 对安全性有特别要求的应用,如:生命支持、主动植入设备或对产品功能安全有要求的系统; (B) 航空应用; (C) 汽车应用或汽车环境; (D) 航天应用或航天环境,且/或(E) 武器。因雅特力产品不是为前述应用设计的,而采购商擅自将其用于前述应用,即使采购商向雅特力发出了书面通知,风险由购买者单独承担,并且独力负责在此类相关使用中满足所有法律和法规要求。

经销的雅特力产品如有不同于本文档中提出的声明和 / 或技术特点的规定,将立即导致雅特力针对本文所述雅特力产品或服务授予的任何保证失效,并且 不应以任何形式造成或扩大雅特力的任何责任。

© 2021 雅特力科技 (重庆) 有限公司 保留所有权利